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of Rolf E. Carlson ^ 

Inventor(s) 
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Title of invention 

1. Copy of Prior Application as Filed That is Attached, 

13 I hereby verify that the attached papers are a true copy of what is shown in my records to 
be the above identified prior application, including the oath or declaration originally filed. 
(37 CFR §1 .60(b)(2)) 

The copy of the papers of prior application as filed which are attached are as follows: 
13 32 page(s) of specification 

^ 10 page(s) of claims 

[3 _1 page(s) of abstract 

^ _9 page(s) of drawings 



{If the copy of the declaration being filed does not show applicants signature, because 
the attorney's records do not contain a copy of the signed declaration actually filed for the 
application, indicate thereon that it was signed and complete the following:) 

□ in accordance with the indication required by 37 C.F.R. 60(b), my records reflect 
that the original signed declaration showing applicant's signature was filed on 



□ The amendment referred to in the declaration filed to complete the prior application and I 
hereby state, in accordance with the requirements of 37 CFR 1.60(b), that this 
amendment did not introduce new matter therein. 



(also complete part 6 below, if drawings are to be transferred) 
pages of declaration and power of attorney 
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2. Amendments 



1^ Cancel in this application original claims 1-16, 23-28 of the prior application 

before calculating the filing fee. (At least one original independent claim must be retained 
for filing purposes.) 

□ A preliminary amendment is enclosed. (Claims added by this amendment have been 
properly numbered consecutively beginning with the number next following the highest 
numbered original claim in the prior application.) 

NOTE: When filing under Rule 1.60 retain at least one original claim from the patent application to assure a complete 
application." Notice of March 3, 1986 (1064 O.G. 37-38). 

3. Petition for Suspension of Prosecution for the Time Necessary to File an Amendment. 

(check the next item, if applicable) 

□ There is provided herewith a Petition To Suspend Prosecution For The Time Necessary 
to File An Amendment (New Application Filed Concurrently). 

4, information Disclosure Statement 

(check this item if applicable) 
13 An information disclosure statement is submitted herewith. 



5. Fee calculation (37 CFR 1,16) 

A. Utility (37 C.F.R. 1.16(a), (b), (c), and (d)) 



CLAIMS AS FILED 


Number Filed 


Number Extra 




Rate 


Basic Fee 

(37 CFR 1.16(a)) 
$790-00 


Total 

Claims f37 CFR §1,16fc))6 


-20 = 0 


X 


$22.00 


0 


Independent 

Claims (37 CFR §1.1 6(b)) 1 


-3 = 0 


X 


$82.00 


0 


Multiple dependent claim(s) , if any 
(37 CFR §1.1 6(d)) 


0 


+ 


$270.00 


0 



□ Fee for extra claims is not being paid at this time. (37 CFR §1. 16(d)) 



Filing fee Calculation $ 790.00 

B. Design (37 C.F.R. 116(f)) 

Filing fee calculation $ 320.00 

6. Small Entity Status 

□ A verified statement that this filing is by a small entity: 
□ is attached 
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□ has been filed in the parent application and such status is still proper and desired (37 
CFR §1 .28(a)) 

Filing fee Calculation (50% of Above) $ 

7. Drawings 

Drawings are enclosed 

□ Formal 
13 Informal 

NOTE: "Identifying indicia, if provided, should include the application number or the title of the invention, inventor's 
name, docket number (if any), and the name and telephone number of a person to call if the Office is unable to 
match the drawings to the proper application. This information should be placed on the back of each sheet of 
drawings a minimum distance of 1.5 cm. (5/8 inch) down from the top of the page." 37 CFR §1. 84(c)). 

8. Priority- 35 U.S.C. 119 

□ Priority of application serial No. filed on in 

is claimed under 35 U.S.C. 119. 

Country 

□ The certified copy has been filed in prior U.S. application Serial No. 
on . 

□ The certified copy will follow. 



9. Relate Back - 35 U.S.C. 120 

^ Amend the specification by inserting, before the first line, the following sentence: 
"This is a 

□ continuation 
^ divisional 

of copending application(s) 

13 Serial number 08/358,242 filed on 12/19/94 " 

□ International Application filed on that 

designated the U.S." 



10. Inventorship Statement 

(complete appropriate items (a) and (b)) 

(a) With respect to the prior copending U.S. application from which this application claims 
benefit under 35 U.S.C. 120 the inventor(s) in this application is (are): 

(complete applicable item below) 

K the same. 

□ less than those named in the prior application. It is requested that the following 
inventor(s) identified above for the prior application be deleted: 



37 CFR 1.60(b) P.3 of 7 



(type name(s) of inventor(s) to be deleted) 
(b) The inventorship for all the claims in this application is 
^ the same. 

□ not the same, and an explanation, including the ownership of the various claims at the 
time the last claimed invention was made, is submitted. 

11. Assignment 

^ The prior application is assigned of record to 

Mikohn Gaming Corporation at Reel 8692, Frame 0513 

□ An assignment of the invention to ^ 

is attached. A separate 

□ "COVER SHEET FOR ASSIGNMENT (DOCUMENT) ACCOMPANYING NEW 
PATENT APPLICATION" 

or 

□ FORM PTO 1595 
is also attached. 

12. Fee Payment Being Made At This Time 

□ Not enclosed 

□ No filing fee is submitted. 

(This and the surcharge required by 37 CFR 1.16(e) can be paid subsequently.) 
^ Enclosed 

[gl basic filing fee $ 790.00 

□ recording assignment 
($40.00; 37 CFR 1.21(h)) 

(See attached "COVER SHEET FOR 
ASSIGNMENT ACCOMPANYING NEW 
PATENT APPLICATION".) 

□ processing and retention fee 

($130.00; 37 CFR 1.53(d) and 1.21(1)) $ 

Total Fees Enclosed $ 790.00 

13. Method of Payment of Fees 

^ Enclosed is a check in the amount of $ 790.00 . 

□ Charge Deposit Account No. in the amount of $ . A 

duplicate of this request is attached. 

14. Authorization To Charge Additional Fees 

13 The Commissioner is hereby authorized to charge any additional filing fees to Account 
No. 04-1414 . 

^ 37 CFR 1.16(a), (f) or (g) (filing fees) 
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□ 37 CFR 1.16(b), (c) and (d) (presentation of extra claims) 

□ 37 CFR §117 (application processing fees) 

□ CFR §118 (issue fee at or before mailing of Notice of Allowance, pursuant to 37 CFR 
§131 1(b)) 

15. Power of Attorney 

^ The power of attorney in the prior application is to 



Robert C. Dorr 27.782 



Attorney 


Reg. No.# 


W. Scott Carson 


27.292 


Attorney 


Reg. No.# 


Jack C. Sloan 


26,806 


Attorney 


Reg. No.# 


Thomas S. BIrnev 


30.025 


Attorney 


Reg. No.# 



a. [3 The power appears in the original papers in the prior application. 

b. □ Because the power does not appear in the original papers, a copy of the power in the 

prior application is enclosed. 

c. □ A new power has been executed and is attached. 

d. ^ Address all future communications to 

(item d may only be completed by applicant, attorney or agent of record) 

Name: Robert C. Dorr 

Address: DORR. CARSON, SLOAN & BIRNEY. P.C.. 3010 East 6th Avenue, Denver 

Colorado 80206 „ 

16. Maintenance of Copendency of Prior Application 

(this item must be completed and the papers filed in the prior application if the period set in the prior 

application has run) 

□ A petition, fee and response has been filed to extend the term in the pending prior 
application until : 

□ A copy of the petition for extension of time in the prior application is attached. 

17. Conditional Petition for Extension of Time In Prior Application 

(complete this item and file conditional petition in the prior application if previous item not applicable) 

□ A conditional petition for extension of time is being filed in the pending parent application. 

□ A copy of the conditional petition for extension of time in the prior application is 
attached. 

18. Abandonment of Prior Application (if applicable) 
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□ Please abandon the prior application at a time wliile tlie prior application is pending or 
wiien the petition for extension of time or to revive in that application is granted and when 
this application is granted a filing date so as to make this application copending with said 
prior application. 

19. Notification in Parent Application of the Filing of This Continuation Application 

^ A notification of the filing of this continuation is being filed in the parent application from 
which this application claims priority under 35 USC §120. 

20. Statement by Assignee {if applicable) 

n In accordance with 37 CFR 3.73, 1 have reviewed the evidentiary documents establishing 
my/our ownership of the application identified herein, and certify that to the best of my/our 
knowledge and belief, title is with me/us who seek to take action. 

□ Assignment submitted herewith for recordal 

I hereby declare further that all statements made herein of my own knowledge are true 
and that all statements made on information and belief are believed to be true; and further that 
these statements were made with the knowledge that willful false statements and the like so made 
are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the United 
States Code, and that such willful false statements may jeopardize the validity of the application or 
any patent issuing thereon. 



(type or print name of person signing declaration) 



Date Signature 



P.O. Address of Signatory 



Tel. No.: ( ) 

Reg. No. of applicable) □ Inventor 

□ Assignee of complete interest 

□ Person authorized to sign on behalf of 
assignee 

□ Attorney or agent of record 

□ Filed under Rule 34(a) 

{complete the following, if applicable) 



(Type name of assignee) Title of person authorized to sign on behalf of assignee 



Address of Assignee 
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Assignment recorded in PTO on , Reel , Frame 

Assignment recorded in PTO on , Reel , Frame 

The statement under 37 CFR §3.73(b) 

□ has been filed in the parent application. 

□ a copy of the statement previously filed in the parent application is attached. 



Reg. No. 27,782 
Date: I 

Tel. No. ( 303 ) 333-3010 



Signature of Practitioner 

Roberto. Dorr 

Type or Print Name of Practioner 

Dorr Carson, Sloan & Birnev, P.O. 
P.O. Address 

3010 East 6th Avenue 

Denver, Oolorado 80206 
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UNIVERSAL GAMING ENGINE 

BACKGROUND OF THE INVENTION 

1, Field Of the Invention. 

The present invention relates , in general , to 
5 gaming machines, and, more particularly, to an 
electronic gaming engine supporting multiple games 
and multiple users. 

2> Statement of the Problem, 

Cas ino gaming has grown rap idly in the United 
10 States. Casino gaming is experiencing similar growth 
throughout the world. An important segment of this 
developing industry is electronic games. An 
electronic implementation of a game requires a method 
for interpreting hxman actions as they occur within 
15 the constraints of the rules as well as the ability 
to respond with chance events. 

Microprocessors allow games that formerly relied 
on analog devices for generating chance events, such 
as dice, to be simulated digitally. Simulating a die 
20 roll with a computer would seem to be a contradiction 
because the microprocessor is the embodiment of logic 
and determinism. With care, however, it is possible 
to create deterministic algorithms that produce 
unpredictable, statistically random nxombers. 

2 5 Contemporary games consist of a framework of 

rules that define the options for how a user or 
random event generator may change the game state . 
Play begins with an initial state. Subsequent play 
consists of user initiated events that trigger the 
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execution of one or more rules. A rule may proceed 
deterainistically or non-deteministically. 

Typical games consist of deterministic and non- 
deterministic rules. A game progresses by the 
interaction of these rules. There are two soxirces 
for non-determinism:^ player decisions and chance 
events • In the game of Poker, for example, deciding 
to replace three instead of two cards in a hand is a 
player decision that is limited, but not pre- 
determined, by rules. The rules limit the range of 
options the player has , but within that set of 
options the player is free to choose. An example of 
a chance event is the random set of cards received by 
the poker player. Shuffled cards do not produce a 
predictable hand. 

other examples that illustrate determinism and 
non-determinism in gaming are popular casino pastimes 
such as Blackj ack , Keno , and Slot machines . The 
first Blackjack hand a player receives is two cards 
from a shuffled deck. The nxamber of cards dealt is 
two, but the cards could be any from the deck. Keno 
is essentially a lottery. In Keno, a player attempts 
to guess twenty balls chosen from a basket of eighty 
balls . The rules dictate that to participate , a 
player must fill out a Keno ticket indicating the 
balls he believes will be chosen in the next round, 
the selection of balls , however , is a purely random 
event. Slot machines require the player to pull a 
handle for each round. Slot wheels stop at random 
positions. 

The non-deterministic problem in most parlor 
games is random sampling without replacement: given 
a set of n elements, randomly choose m of them 
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without replacement where m is less than or equal to 
n. Although sampling without replacement covers most 
popular games, it would be easy to conceive of games 
that required replacement. For example, consider a 
5 variant of Keno that replaces each chosen ball before 
selecting the next ball. Until now, no device is 
available that seirvices the needs of multiple games 
by providing algorithms for sampling with and without 
replacement as well as others such as random 
10 permutation generation, sorting, and searching. 

A cas ino player must 3cnow the 1 ikel ihood of 
winning a j ac3q)ot is commensurate with the stated 
theoretical probabilities of the game. Moreover, the 
casino would like to payout as little as possible 

15 while maximizing the nximber of their game 
participants. Because each game sponsored by a 
casino has a built-in theoretical edge for the house, 
over time and with repeated play, the house will make 
money. In other words, the casino does not need to 

20 cheat the customer because it has a built-in edge. 
The customer , who is at a disadvantage in the long 
run, will want to know the game is fair in order to 
manage risk. In is a theoretical fact that bold 
wagering in Roulette increases a players odds of 

25 winning. A player who cannot know the odds of 
winning cannot formulate a strategy. 

Provided that the deterministic rules of a game 
are implemented correctly, it is essential that the 
chance events of a game are indeed random . an 
3 0 important subproblem for generating random events is 
xiniform random niimber generation. If the underlying 
uniform random number generator does not generate 
statistically independent and uniform pseudo-random 
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nxombers, then either the house or customer will be at 
a disadvantage. A poorly designed system might favor 
the house initially and over time turn to favor the 
player. Certainly the house would not want this 
5 situation because it makes revenue projection 
impossible. Any regulatory body would like to ensure 
that neither the house nor customer have an advantage 
beyond the stated theoretical probabilities of the 
game. In the context of fairly implemented rules, 
10 the only way for the house to increase its revenue is 
to increase the number of players pairticipating in 
their games. 

Typically, an engineer creating an electronic 
game generates a flow chart representing the rules 

15 and uses a random niomber generator in conjunction 
with combinatorial algorithms for generating chance 
events . Representing rules is one problem. 

Generating chance events to support those rules is 
another. Creating pseudo-random numbers is a subtle 

20 problem that requires mathematical skills distinct 
from other problems of gaming . In other words , a 
skilled game programmer may be unable to solve the 
problems of developing a proper random number 
generator . Even if given a quality random number 

25 generator, problems can occur in hardware 
implementations that render the generator 
predictable. One example is using the same seed, or 
initial state, for the generator at regular intervals 
and repeatedly generating a limited batch of numbers. 

3 0 Without attending to the theoretical aspects of a 
uniform random number generator, it is not possible 
to implement the rules of a game perfectly . The 
result is a game unfair to the house, players, or 
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both . Hence , there is a need for a gaming system , 
apparatus, and method that separate the problem of 
implementing game rules from that of random event 
generation. 

5 The need for such a device is also evident at 

the regulatory level. Gaming is a heavily regulated 
industry. States, tribes, and the federal government 
have gaming regulatory agencies at various levels to 
ensure fairness of the games. The gaming regulatory 

10 authority certifies that a particular implementations 
of a game reflects the xinderlying probabilities. 
Because electronic games are" implemented in often 
difficult to xinderstand software, the problem of 
verifying fairness of a game is challenging . 

15 Further, there is little uniformity in the 
implementation of fxindamental components of various 
games. To determine fairness, the gaming authority 
subjects each game to a battery of tests. No set of 
statistical tests performed on a limited portion of 

20 the random number generator period can ensure that 
the generator will continue to perform fairly in the 
field. The process of testing is both expensive and 
of limited accuracy. Hence, a regulatory need exists 
for a uniform, standardized method of implementing 

25 games that reduce the need and extent of individual 
game testing while increasing he reliability of 
detecting and certifying game fairness. 

3, Solution to the Problem^ 

The Universal Gaming Engine (UGE) in accordance 
30 with the present invention is a gaming apparatus 
providing a consistent game development platform 
satisfying the needs of the gaming authority, house. 
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player, and game developer. The UGE separates the 
problems of developing game rules from the difficulty 
of producing chance events to support those rules • 
Functions that are common to a number of games are 
5 included in the gaming engine so that they need not 
be implemented separately for each game. By 
including basic functions shared by a number of 
games, hardware costs are greatly reduced as new 
games can be implemented merely by providing a new 
10 set of rules in the rules library and the basic 
hardware operating the game remains unchanged. 
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SUMM&RY OF THE INVEMTION 

Briefly stated, the present invention provides a 
system, apparatus, and method for implementing a game 
having a deterministic component and a non- 
5 deteministic component wherein a player uses the 
game through at least one player interface unit. 
Each player interface unit generates a player record 
indicating player- initiated events. A random number 
generator provides a series of pseudo-random numbers 
10 that are preferably statistically verified by 
integral verification algorithms and stored in a 
buffer. Preferably, the random number generator 
allows seed and key restoration automatically or 
manually upon power fault. 

15 A rules library stores indexed rules for one or 

more games . An interface registry stores mapping 
records where the mapping records are used to 
associate the player-initiated events to pre-selected 
rules in the rules library. A control means is 

20 coupled to receive the output of the player interface 
unit, coupled to the interface registry, the rules 
library, and the random nvunber generator. The 
control means processes the player record and returns 
an output record to the player interface unit where 

2 5 the output record is determined by executing the 
game ' s rules with reference to the pseudo-random 
numbers and predefined combinatorial algorithms for 
selecting sets of the pseudo-random numbers. 
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BRIEF DESCRIPTION OF THE DRAWING 

Fig, 1 illustrates a simplified block diagram of 
the gaming engine in accordance with the present 
invention ; 

5 Fig. ^ 2 illustrates a block diagram of the 

pseudo-random nxomber subsystem in accordance with the 
present invention; 

Fig • 3 illustrates the non-uniform distribution 
generator and combinatorial algorithm subsystems in 
10 accordance with the present invention; 

Fig. 4 illustrates a main control circuit in 
accordance with the present invention; 

Fig. 5 illustrates in block diagram form 
implementation of the rules library in accordance 
15 with the present invention; 

Fig. 6 illustrates a flow chart of a game 
implementation using the apparatus shown in Fig. 1; 

Fig. 7 illustrates a flow diagram for a second 
embodiment pseudo-random number distribution system; 

20 Fig. 8 illustrates a multiple player networked 

implementation in accordance with the present 
invention; and 

Fig. 9 illustrates in graphical form 
relationships between server speed, queue size, and 
25 customer wait times of an apparatus in accordance 
with the present invention. 
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DETAILED DESCRIPTION OF THE DRAWING 



1« Overview. 

Fig. 1 illustrates, in simplified schematic 
form , a gaming apparatus in accordance with the 
present invention . The gaming apparatus in 

accordance with the present invention is also 
referred to as a "xiniversal gaming engine" as it 
serves in some embodiments as a platform for 
implementing any number of games having deterministic 
and random components . In other embodiments , the 
\iniversal gaming engine in accordance with the 
present invention provides a platform that supports 
multiple players across a network where each player 
preferably independently selects which game they play 
and independently controls progression of the game. 

Although in the preferred embodiment all of the 
games discussed are implemented entirely 
electronically, it is a simple modification to alter 
the player interface to include mechanical switches, 
wheels, and the like. Even in mechanically 

implemented games electronic functions that are 
performed by the gaming engine in accordance with the 
present invention are required. Hence, these 

mechanical machines are greatly simplified using the 
gaming engine in accordance with the present 
invention. 

Gaming engine 100 is illustrated schematically 
in FIG. 1, including major subsystems in the 
preferred embodiments . Each of the sxibsy stems 
illustrated in Fig. 1 is described in greater detail 
below. Fig. 1, however, is useful in understanding 
the overall interconnections and functioning of the 
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gaming engine in accordance with the present 
invention. 

Gaming engine 100 performs several basic 
fianctions common to many electronically implemented 
casino games. The most basic of these fxinctions 
includes interacting with the player to detect player 
initiated events, and to communicate the state of a 
game to the player. Gaming engine 100 must process 
the player initiated event by determining the 
appropriate rules of the game that must be executed 
and then executing the appropriate rules. Execution 
of the rules may require only simple calculation or 
retrieving information from memory in the case of 
deterministic rules, or may require access to pseudo- 
random values or subsets of pseudo-random values in 
the case of non-deterministic components. 

Gaming engine 100 in accordance with the present 
invention uses a main control circuit 101 to control 
and perform basic functions . Main control circuit 
101 is a hardware or software programmable 
microprocessor or microcontroller . Alternatively , 
main control circuit 101 can be implemented as an 
ASIC device with dedicated logic to perform the 
required control functions. Main control circuit 101 
communicates with pi ay er int er f ace unit 102 via 
interface bus 103. Player interface unit 102 is a 
machine having at least some form of display for 
communicating information to the player and some form 
of switch (i.e., buttons , levers , keyboard , coin 
slot, or the like) for commxinicating information from 
the player. 

Player interface unit 102 generates a player 
record of information and transmits the player record 
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over bus 103 to main control circuit 101. The player 
record of information contains information about the 
player initiated event as well as any data that may 
be associated with the particular event. For 
example, a player initiated event may be drawing two 
cards from a deck of cards. The player record will 
include information about the event (i.e., drawing 
cards ) , and data (i.e., two cards ) . The player 
record may include other information such as the 
state of the game that is being played. By "state of 
the game" it is meant at which stage in the rule 
defined progression of the game the game ctirrently 
exists. State information may be maintained by 
gaming engine 100 or player interface unit 102 , or 
both. 

Main control circuit 101 responds to a player 
initiated event by referencing a public interface 
registry 107. Public interface registry 107 is 
essentially a lookup table implemented in volatile , 
semi-volatile, or non-volatile memory. Public 
interface registry 107 is desirably organized as an 
addressable memory where each address is associated 
with a mapping record. Main control circuit 101 uses 
the player event portion of the player record to 
address public interface registry 107 in a preferred 
embodiment. Public interface registry 107 then 
provide a selected mapping record to main control 
circuit 101 . Main control circuit 101 uses the 
selected mapping record to address rules librairy 108. 

Rules library 108 is essentially an addressable 
memory preferably allowing random access. Rules 
library 108 can be implemented in volatile, semi- 
volatile, or non-volatile memory of any convenient 
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organizational structure. Rules library 108 responds 
to the address from main control circuit 101 by 
supplying one or more rules, which correspond to game 
rules, to main control circuit 101. The rules 
provided by rules library 101 are preferably 
executable instructions for main control circuit 101. 

Main control circuit 101 processes the selected 
rules by selectively accessing random nvimber circuit 
104 and transform function algorithms 106. As set 
out herein before, completely deterministic rules may 
be executed entirely within main control circuit 101 
by simple calculations or data transfer operations. 
Where the selected rule requires laain control circuit 
101 to access one or more pseudo-random numbers, 
random nvunber circuit 104 is accessed. In the 
preferred embodiment random number circuit 104 
provides a series of pseudo-random numbers of 
-arbitrary length having uniform distribution as 
described in greater detail hereinafter. 

Often times, however, a rule will require a non- 
xiniform distribution of pseudo-random ntambers, or 
some subset of a series of pseudo-random numbers. In 
this case, main control circuit 101 implements the 
selected rule by accessing transform fiinction 
algorithms from block 106 in Fig. 1. The transform 
function algorithms transform the series of uniformly 
distributed pseudo-random numbers from random number 
circuit 104 by 1) transforming them into a non- 
uniform distribution, 2) using a given set of the 
uniformly distributed pseudo-random numbers to 
performing set selection permutations or 3) both. 

In this manner, the basic functions of pseudo- 
random number generation, pseudo-random number 
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transformation, and association of rules with player 
or player events are standardized and entirely 
contained in gaming engine 100. System operator 
interface 109 is used by the casino or game developer 
to communicate with uniform random niamber circuit 104 
and main control circuit 101.^ This communication is 
desirable to initialize, program, and maintain main 
control circuit 101 and public interface registry 
107 , for example . System operator interface also 
enables an operator to initialize, monitor and change 
seed values and key values used by uniform random 
number circuit 104. Any convenient hardware may be 
used to implement system operator interface 109 
including DIP switches , a smart terminal , personal 
computer, or a dedicated interface circuit. 

To implement a game, a game programmer develops 
a series of rules for the game. The series of rules 
.are stored as a volume in rules library 108. The 
game programmer will then register the new game in 
pxiblic interface registry 107 by storing the location 
of the voliome of rules in an appropriate address in 
public interface registry 107. The game programmer 
does not need to program or develop the random number 
circuit or transform algorithms to implement a new 
game. Further, the player using player interface 
unit 102 can access any of the games stored in rules 
library 108 . To certify a new game, a game 
regulatory authority need only review the rules in 
the rules library 108 to verify that they follow the 
established rules for a particular game . This 
verification can be easily done by reviewing high- 
level language code such as FORTRAN, C, or Basic. 
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While the present invention is described in 
terms of the preferred implementation of casino games 
it should be xinderstood that any game which has a 
random component and progresses by following pre- 
defined rules can be implemented in gaming engine 
100. Player interface unit 102 may be entirely 
electronic or combine electronic and mechanical 
components. Player interface unit may supply any 
amount and kind of information in addition to the 
basic functions set forth above to main control 
circuit 101. Player interface unit 102 may be 
located in the same physical machine as the remaining 
portions of gaming engine 100 or may be located at a 
great distance from gaming engine 100. These and 
other alternatives will be discussed in greater 
detail hereinafter. 



2. Ramdom Nn^ l^^y Gireuit. 

A preferred random number circuit 104 is shown 
in Fig. 2. Random number circuit 104 preferably 
includes random nxomber generator circuit 201, 
verification algorithms 202, and buffer 203. Random 
nxomber circuit 104 is controlled by random number 
control circuit 204 which is a microprocessor, 
microcontroller, or dedicated logic control circuit. 

Random number generator circuit 201 provides a 
stream of uniformly distributed pseudo-random numbers 
on output 206. Alternatively , random niimber 

generator circuit 201 can provide parallel outputs on 
output 206. Also, more than one random number 
generator circuit 201 may be employed depending on 
the quantity of pseudo-random numbers demanded by the 
system. 
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Random nioiober generator circuit 201 preferably 
supplies uniformly distributed pseudo-random numbers 
because a set of uniformly distributed nxombers can be 
transformed easily by transform algorithms 106 into 
non-uniform distributions and combinatorial subsets. 
A preferred circuit for implementing random number 
generator circuit 201 is an ANSI X9.17 pseudo random 
nximber generator based upon a plurality of data 
encryption standard ( DES ) encryption circuits . 
Alternatively , random number generator circuit 201 
may be implemented using the international data 
encryption algorithm (IDEA) encryption^ Other random 
number generator circuits are known • When 
implementing other random ntimber generator circuits 
201, however, it should be appreciated that a high- 
quality, cryptographically strong pseudo-random 
niomber generator is preferable. A major advantage of 
the present invention is that the random ntomber 
circuit 104 need be implemented only once to serve a 
plurality of games making it cost efficient to use 
relatively expensive circuitry to provide a high 
quality random niombered circuit 104. 

Random nxamber generator circuit 201 accepts as 
input one or more key values which are typically 
binary values having a fixed relatively large nimber 
of bits. For example, the ANSI X9.17 pseudo-random 
number generator uses 56-bit keys. Random generator 
circuit 201 also usually accepts a seed value, which 
is also another large bit binary value. Further, 
random number generator circuit 201 has a data input 
or clock input that accepts a continuously variable 
signal which is conveniently a clock representing 
date and time. In this manner, each time the signal 
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on the clock or data input changes a new random 
number is output on line 206. Random number control 
circuit stores and provides the key values, seed 
value, and clock values to random number generator 
circuit 201. 

A desirable feature in -accordance with the 
present invention is that random number circuit 104 
be able to boot up after a power fault (i.e., power 
is removed from the sytsem) using the same seed 
values, key values, and clock value that existed 
before the power fault . This feature prevents a 
player or operator from continually resetting the 
system or gaining any advantage by removing power 
from gaming engine 100. One way of providing this 
fiinctionality is to buffer the key values, seed 
values , and clock values in memory within random 
number control circuit 204 before they are provided 
to random niimber generator 201. After a power on 
default, circuit 104 can reboot autonomously using 
the values stored in buffers. Alternatively, new 
values can be provided via system operator interface 
109 to ensure that the output after a power fault is 
in no way predictable based upon knowledge of output 
after a prior power fault. 

In a preferred embodiment, random nxmber 
generator circuit operates continuously to provide 
the series of random numbers on line 206 at the 
highest speed possible. By continuously, it is meant 
that random number generator circuit 201 operates at 
a rate that is not determined by the demand for 
random numbers by the rest of the system. Random 
nijmber control circuit 204 provides key values, seed 
values, and data values to random number generator 
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circuit 201 independently of any processing demands 
on main control circuit 101 (shown in Fig. 1) . This 
arrangement ensures that random number circuit 104 
operates at a high degree of efficiency and is not 
slowed down by computational demands placed on main 
control circuit 101. In other words, the control 
circuit resoxirces that implement random number 
control circuit 204 are independent of and usually 
implemented in a separate circuit from main control 
circuit 101. 

Random number control circuit 204 accesses one 
or more verification algorithms 202 via connection 
207. Verification algorithms 202 serve to verify 
that the raw random numbers on line 206 are 
statistically random to a predetermined level of 
certainty. Preferably, verification algorithms 202 
include algorithms for testing independence, one- 
dimensional laniformity, and multi-dimensional 
uniformity. Algorithms for accomplishing these tests 
are well known. For example, independence of the 
pseudo random numbers can be performed by a Runs 
test. Uniformity can be verified by the Kolmorgorov- 
Smimov or K-S test. Alternatively, a Chi-square 
test verify uniformity. A serial test is an 
extension of the Chi-square test that can check 
multi-dimensional uniformity. 

Random nxamber control circuit 204 preferably 
receives and stores a set of raw random numbers from 
random number generator circuit 201. The set of raw 
random nimbers can be of any size, for example 1000 
numbers. Random number control circuit 204 then 
implements the verification algorithms either 
serially or in parallel to test independence and 
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xinifonaity as described hereinbefore. It may be 
advantageous to use more than one physical circuit to 
implement random nxxmber control circuit 204 so that 
the verification algorithms may be executed in 
parallel on a given set of raw random numbers. 

I f a set of raw random niombers do not pass one 
of the verification tests the nxombers are discarded 
or overwritten in memory so that they cannot be used 
by gaming engine 100. Only after a batch of numbers 
passes the battery of verification tests, are they 
passes via line 208 to verify random number buffer 
203 . Buffer 203 is preferably implemented as a 
first-in, first-out (FIFO) shift register of 
arbitrary size. For example, buffer 203 may hold 
several thousand or several million random numbers. 

By integrating verification algorithms 202 in a 
random number circuit 104 , gaming engine 100 in 
accordance with the present invention ensures that 
all of the pseudo-random niambers in buffer 203 are in 
fact statistically random. This overcomes a common 
problem in pseudo-random niimber circuits wherein the 
random numbers are long-term random, but experience 
short-term runs or trends. These short-term trends 
make prediction of both the player and casino odds 
difficult and may create an illusion of unfaiimess 
when none in fact exists . The verification 

algorithms 202 in accordance with the present 
invention largely eliminate these short-teann trending 
problems and create a pool of random n\ambers in 
buffer 203 that are both statistically random and 
will appear to be random in the short run time period 
in which both the casino and players operate. 
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Buffer 203 makes the random numbers available 
continuously to main control circuit 101. Main 
control circuit 101 may access any quantity of the 
numbers in buffer 203 at a time . Buf f er 203 also 
serves to provide a large quantity of random numbers 
at a rate higher^ than the peak generation rate of 
random number generator circuit 201. Although it is 
preferable that random number generator circuit 201 
and verification algorithms 202 are processed so as 
to provide random numbers to buffer 203 at a higher 
rate than required by gaming engine 100, short-term 
bursts of random nimbers can be provided by buffer 
203 at a higher rate. 

3, Transform Function Algorithms, 

Transform function algorithms 106 are accessed 
by main control circuit 101 as illustrated in Fig. 3. 
Examples of transform function algorithms 106 are a 
non-uniform distribution generator 301 and 
combinatorial algorithms 302. To execute some rules 
obtained from rules library 108, main control circuit 
101 may be required to select one or more random 
values from a non-uniform distribution. Examples of 
non-uni form distributions are normal distribution , 
exponential distribution, gamma distribution, as well 
as geometric and hypergeometric distributions. All 
of these non-uniform distributions can be generated 
from the uniform distribution provided by random 
number circuit 104 . 

Rule implementations primarily require that main 
control circuit 101 access a series of pseudo-random 
numbers in the context of random set selection and 
permutations. This subset selection is performed by 
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combinatorial algorithms 302 . The combinatorial 
algorithms 302 operate on either the uniform nximber 
distribution provided directly by random niomber 
circuit 104 or the non-xiniform distribution provided 
by non-uniform distribution generator 301. In this 
manner , a game of keno can be implemented by 
selecting a random 20 from a group of 80. 

Another function of the transform algorithms 106 
is to scale and center the series of random numbers. 
For example, a deck of cards includes 52 cards so 
that the set of random nxombers must be scaled to 
range from 1 to 52. These and similar transform 
fTinctions are well known. 

An advantageous feature of the present invention 
is that these transform functions can be implemented 
a single time in a single piece of software or 
hardware and selectively accessed by any of the games 
in rules library 108. This allows a great variety of 
transform functions to be provided in a cost 
efficient and computationally efficient manner. The 
game designer need only provide rules in rules 
library 108 that access appropriate transform 
function algorithms 106 and need not be concerned 
with the details of how the transform function 
algorithms 106 are implemented. Similarly, a gaming 
regulatoiry authority can verify the correctness and 
fairness of transform algorithms a single time by 
providing extensive testing . Once the trans foina 
functions are verified, they need not be verified 
again for each game that is implemented in rules 
library 108 . This independence between the rules 
programming and the non-deterministic programming 
result in highly standardized and reliable games 
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while allowing the games designer greater flexibility 
to design a game in the rules library 108, 

4, Main Control Circuits 

A preferxed embodiinent of main control circuit 
5 101 is shown in block diagram form in Fig, 4. 
Preferably, a micro-controller microprocessor 401 is 
provided to perform calculations , memory 
transactions, and data processing- Microprocessor 
401 is coupled through bus 103 to player interface 
10 unit 102. Microprocessor 401 is also coupled to 
player number circuit 104, transform function 
algorithms 106, public interface registry 107, and 
rules library 108 through bi-directional 
communication lines 402. 

15 In a typical configuration, main control circuit 

101 will have a quantity of HAM/SHAM 403, a quantity 
of non-volatile memory 404, and ROM for storing an 
operating system and boot sequence. ROM 406 operates 
in a conventional manner and will not be described in 

20 greater detail hereinafter. Non-volatile memory 404 
is an addressable, preferably random access memory 
used to store information that is desirably saved 
even i f power i s removed f r om ma in contr o 1 c ir cuit 
101. For example, microprocessor 401 may calculate 

2 5 statistics regarding the type of games played , the 

rate of game play, the rate of nxamber request, or 
information about the player from player interface 
unit 102. The statistics are preferably stored in a 
non-volatile memory 404 to maintain integrity of the 

3 0 information. Similarly, non-volatile memory 404 may 

be used to maintain the state of a game in progress 
on player interface unit 102 so that is power is 
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removed, universal gaming engine 100 can restore 
player interface unit 102 to the state at which it 
existed prior to the power outage* This may be 
important in a casino operation where the casino 
could incur liability for stopping a game when the 
player believes a payoff is imminent. 

RAM 403 serves as operating memory for temporary 
storage of rules access from rules library 108 or for 
storing the operating system for quick access • RAM 
403 may also store groups of random numbers while 
they are being processed by the transform function 
algorithms as well as address data provided to and 
accepted from the public interface registry. 

It should be understood that main control 
circuit 101 may be implemented in a variety of 
fashions using conventional circuitry. While some 
memory will almost surely be required, the memory may 
be implemented as RAM, SRAM, EPROM or EEPROM to meet 
the needs of a particular application . Similarly , 
the components of main control circuit 101 shown in 
Fig. 4 may be implemented as a single circuit or 
single integrated circuit or in multiple circuits or 
integrated circuits. Additional features may be 
added to implement additional functions in a 
conventional manner. 

5, Rules Library* 

An exemplary embodiment of rules library 108 is 
illustrated in block diagram form in Fig. 5. Rules 
library 108 is preferably implemented as a plurality 
of volumes of rules where each volume is fixed in a 
3:ule EPROM 502-506. Any number of rule EPROM' s can 
be supplied in rule library 108. Also, rule EPROM' s 
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502 can be of various sizes. Rule EPROM^s 502-506 
may be replaced with equivalent memory circuits such 
as RAM, S RAM, or ROM. It is desirable from a gaming 
regulatory authority standpoint that rule EPROM*s 
502-506 cannot be altered once programmed so that the 
rules cannot be changed from the designed rules. 
This allows the gaming regulatory authority to verify 
the EPROM rules. 

Address logic 501 provides address signals to 
select one of rule EPROM' s 502-506. Additionally, 
address logic 501 serves to position a pointer to a 
specific rule within each rule EPROM 502-506. As set 
out herein before, which of rule EPROM' s 502-506 is 
selected as determined by the current game being 
played as indicated by player interface unit 102 
(shown in Fig. 1) . The location of the pointer 
within a rule EPROM is addressed based upon the 
current state of the game and the particular user 
initiated event indicated by player interface unit 
102. The information is conveyed from the user 
interface unit 102 in a player record that is mapped 
to rule library 108 by the information in public 
interface registry 107. 

In practice, a game developer will program a 
series of rules that dictate the progression of a 
game in response to user or player initiated events. 
The rules will also dictate when random numbers are 
accessed and the type of random nimbers which should 
be accessed (i.e., uniform or non-uniform 
distributions) . Rules will also control payoffs, and 
place boundaries on the types of player events which 
will be accepted. The game developer will then bum 
these rules, once complete, into a rule EPROM, such 
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as rule EPROM's 502-506. The rule EPROM can then be 
verified by a gaming regulatory authority, and once 
approved, be distributed to owners of gaming engines 
wishing to implement the newly developed game. In 
order to install the new game, the rule EPROM is 
installed in rules library 108 and registered in 
public interface registry 107. The registration 
process described hereinbefore provides gaming engine 
100 the address information necessary to enable 
address logic 501 to access a particular rule in 
rules library 108 and provide that rule on output 
line 507 to main control circuit 101. 

Although rules library 108 has been described in 
terms of a plurality of EPROM's 502-506 wherein each 
EPROM holds one volume of rules pertaining to a 
particular game, it should be apparent that many 
other configurations for rules librairy 108 are 
possible. Rules can be implemented in a single large 
memory or in a serial memory such as a tape or disk. 
Address logic 500 may be integrated in rules library 
108, or may be integrated with main control circuit 
101. Each game may be implemented in a single EPROM 
or may require several EPROM's depending on the 
particular needs of an application. 

6. Method of Operation. 

Fig. 6 and Fig. 7 together illustrate in flow 
chart form a preferred method of operation of gaming 
engine 100 in accordance with the present invention. 
Fig. 6 details operation of a first embodiment single 
player gaming engine 100. When gaming engine 100 is 
started as indicated at 601 in Fig. 6, main control 
circuit 101 is initialized and goes through a boot-up 
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sequence to bring it to an initial state. In this 
initial state it waits for user input at step 604, 
The player input or player record preferably 
indicates the game that is being played, the state of 
5 that game , and user initiated events and data that 
must be processed. Upon receipt of the player ^ 
record, the public registry is addressed in step 606. 
The public registry returns a mapping record that 
matches the user record with a particular rule in the 
10 rules library in step 608. 

One or more rules are accessed in step 608. 
Each of the one or more rules are processed in serial 
fashion in the embodiment illustrated in FIG. 6. One 
rule is processed in each pass through steps 610 - 
15 622 . A logical component of a first roile is 
processed in step 610, where the logical component 
includes processes of memory manipulations , 
calculations, and the like. In step 612 , it is 
determined if the particular rule that was executed 
20 in step 610 requires pseudo-random numbers to 
process. If pseudo-random numbers are required, they 
are retrieved in step 700 which is illustrated in 
greater detail in reference to FIG. 7. 

It is determined if the rule requires any 
25 transform algorithm in step 614. If a transform 
algorithm is required it is obtained in step 616. It 
should be understood that the transform algorithm may 
be permanently resident in the main control circuit 
101 and so the step of obtaining 616 may be trivial. 
3 0 Once the necessary transfer algorithm is obtained, it 
is determined if the rule is completely processed in 
step 618. If not, flow returns to step 610 and the 
rule logic is executed until the rule is completely 
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processed and a final result of the rule is 
determined. Once the rule is finished, control moves 
from step 618 to result accumulation step 620. 

Each rule accessed in step 608 is processed in a 
similar manner by sequentially selecting each rule in 
step 626 xintil it is determined that all rules have 
been processed in step 622. Once all the rules are 
processed, the accximulated results are returned to 
the player in step 624. The results are of the rule 
are determined in steps 610, 612, and 614 by 
performing any transforms required on the random 
numbers, executing any deterministic components using 
conventional calculations and memory transactions. 

7. Method for Remdom Numb ^^-r gen eration « 

FIG. 7 illustrates a flow chart showing steps in 
filling random nxamber request step 700 in FIG. 6. 
The process shown in FIG. 7 is initiated when request 
614 is made. More accurately, many of the sub- 
processes shown in FIG . 7 are ongoing , but the 
processes for generating and supplying random numbers 
are also responsive to the request for random niombers 
700. 

Continuously ongoing processes include clock 
generation step 706, providing key value (s) step 710, 
and providing seed value ( s ) step 7 12 . The clock 
signal generated in step 706 need not be a real time 
clock, nor does it have to provide a linearly 
increasing or decreasing output. It is sufficient 
that clock 706 output a continuously variable signal 
at a regular interval. As set out herein before, 
clock generation is preferably performed by random 
nucober control circuit 204 shown in FIG. 2. 

Docket Nuinber 1505/5 



27 



In a preferred einbodiment, a signal is generated 
by the occurrence of the player event. For example, 
the time of the player event is determined at step 
704 and may be used as shown in FIG. 7. At step 708, 
the clock signal and the player event signal are 
combined to provide a continuously variable non- 
random signal. Where both the player event signal 
and the clock are digital , the combination can be 
realized as logical function such as AND, OR, XOR, 
NAND or the like. Also, the combination may be a 
concatenation or subtraction function. This feature 
of the present invention is optional, but adds a new 
degree of randoianess. 

At step 714 , a series of raw random numbers is 
generated using the continuously provided key values, 
seed values, and variable signal. The raw random 
numbers are stored at step 716 to build a group large 
enough to be verified during step 718. Groups of raw 
random numbers that fail verification step 718 are 
discarded, while those that pass are stored at step 
720 in buffer 203 shown in FIG. 2. 

In accordance with a first embodiment, the 
verified random numbers are delivered in step 722, 
returning process flow to step 618 shown in FIG. 6. 
In an alternative embodiment shown in FIG. 7, request 
614 is queued at step 728 using RAM 403 shown in FIG. 
4. Request queuing 728 is implemented as a first in 
first out or "push up" register having N queue 
capacity. In one embodiment, N is between 2 and 10. 
Queuing step 728 stores each request and processes 
each request in turn. In this embodiment, delivery 
step 722 serves whatever request is provided during 
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Step 728. Once a request is delivered, the request 
queue is updated in step 724. 

Although the request queue is optional, it 
increases efficiency of random number generation step 
700. This is especially important in the networked 
multi-user embodiment shown in FIG. 8. FIG. 9 
illustrates generally a relationship between server 
speed, queue size, and the average number of 
customers, or requests for pseudo-random mambers, are 
waiting in the system. FIG. 9 is derive by modeling 
gaming engine 800 (shown in FIG. 8) as an M/M/1 queue 
to produce parameters for expected wait times in the 
system. FIG. 9 assumes that requests for pseudo- 
random numbers are made according to a Poisson 
process. This means that the times between 
successive arrivals are independent exponential 
random variables. 

Upon arrival, a customer either immediately goes 
into service if the server is free, or joins queue 
728 if the server is busy. When step 722 finishes 
obtaining the requested subset, the request is 
returned to the game and leaves the system. The next 
request, if any, is serviced. The times required to 
form the requested random subsets are assiomed to be 
independent exponential random variables also. With 
these assumptions, request queue 728 can be viewed as 
an M/M/1 queue. The first two M's indicate that both 
the interarrival times as well as the service times 
for requests are exponential random variables. The 
"1" indicates there is just one server. 

Server speed is largely determined by the 
hardware chosen to implement the present invention, 
and can be easily varied by those of skill in the art 
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to meet the needs of a particular application. As is 
apparent in FIG. 9, higher server speeds result in 
fewer waiting customers. From the lower portion of 
FIG. 9, is apparent that if the queue size is reduced 
to zero (i.e., no request queue), the average wait 
time climbs even with very fast servers. Hence, to 
minimize wait time, a request queue is desirable. 

It should be understood that the process steps 
shown in FIG. 7 may be carried out in any convenient 
order unless expressly specified above. Process 
steps may be carried out in serial or parallel 
depending on the particular capabilities of main 
control circuit 101 shown in FIG. 1. For example, 
where control circuit 101 is multi-tasking or capable 
of parallel processing, several process steps may be 
executed at once. Also, process steps may be added 
to those shown in FIG. 7 to implement additional 
functions without departing from the inventive 
features of the present invention. 

8. Network T iitihediinent . 

FIG. 8 illustrates in block diagram for a 
network embodiment in accordance with the present 
invention. Basic components of gaming engine 800 are 
similar to gaming engine 100 including random number 
circuit 804, transform algorithms 806, public 
interface registry 807, and rules library 808. Main 
control circuit 801 includes all of the functions 
described herein before in reference to main control 
circuit 101 but also includes fxinction for supporting 
network interface circuit 812. Data bus 812 couples 
main control circuit 801 to network interface circuit 
812. 
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The network embodiment shown in FIG. 8 serves a 
plurality of player interface iinits 802a-801e. This 
additional functionality is provided in part by 
network interface circuit 812 and network I/O 
5 circuits 8 12 a-8 12e . Network interface circuit 8 12 
and network I/O c ircuits 8 12 a- 8 12 e can be 
conventional network circuits used for lObaseT, 
ethernet, Appletalk, or other known computer network 
systems. In selecting the network circuits, it is 
10 important that the data throughput is adequate to 
meet the needs of a particular system. 

Network interface circuit 812 communicates a 
plurality of player records of information to main 
control circuit 801. Main control circuit may be a 
15 conventional processing circuit that serially 
processes each of the player records in a manner 
similar to main control circuit 101. Preferably, 
main control circuit 801 includes multitasking or 
parallel processing capabilities allowing it to 
20 process the plurality of player records 
simultaneously - 

Simultaneous processing requires that main 
control circuit 801 access a plurality of rules from 
rules library 808, each of which may require main 

2 5 control \init 801 to request a set of pseudo-random 

nxmbers from random nxamber circuit 804. In a 
preferred embodiment, the multiple requests for 
pseudo-random numbers are stored in a request queue 
implemented in memory of main control circuit 801. 

3 0 The request queue is preferably able to store more 

than one request. A suitable request queue can store 
ten requests. Random niimber circuit 804 treats each 
request from the request queue of main control 
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circuit 801 in a manner similar to the requests from 
main control circuit 101 described herein before. 
The combination of the request queue with the buffer 
of random number circuit 804 allows gaming engine 800 
5 to service requests corresponding to player initiated 
events very efficiently- A request queue holding 
even two or three requests can reduce the probability 
of any player waiting for delivery of a set of 
pseudo-random ntimbers significantly. 

10 The request queue can be implemented by 

configuring a portion of the RAM available to main 
control circuit 801 as a first-in first-out register 
or push up stack. Each request for a set of random 
numbers is initially placed at the bottom of the 

15 request queue and sequentially raised in the request 
queue until the request is filled. This operation is 
described herein before with respect to FIG. 7. 

By now it should be appreciated that an 
apparatus, method, and system for gaming is provided 

20 with greatly improved efficiency and quality over 
existing gaming methods and systems. The universal 
gaming engine in accordance with the present 
invention is a gaming apparatus providing a 
consistent game development platform satisfying the 

25 needs of gaming authorities, house, player, and game 
developer. The gaming engine in accordance with the 
present invention separates the problems of 
developing game rules from the difficulty of 
producing chance events to support those rules. By 

3 0 including basic functions shared by a nximber of 
games, hardware costs are greatly reduced as new 
games can be implemented merely by providing a new 
set of rules in the rules library and the basic 
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hardware operating the game remains vmchanged* It is 
to be expressly iinderstood that the claimed invention 
is not to be limited to the description of the 
preferred embodiments but encompasses other 
5 modifications and alterations within the scope and 
spirit of the inventive concept. 
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I CLAIM: 

1 • An apparatus for implementing a game , the 
game having a deterministic component, a rule based 
non-deterministic component, and a random component, 
the apparatus comprising: 
5 a first player interface unit generating at 

least a first player record of information indicating 
player- initiated events from a first player; 

a random number circuit providing an output 
signal comprising a series of uniformly distributed 
10 pseudo-random numbers; 

verification means coupled to receive the output 
signal from the random number circuit for verifying 
that the received pseudo-random numbers are 
statistically random, the verification means having 
15 an output for supplying a series of verified pseudo- 
random numbers; 

buffer means coupled to receive the verified 
pseudo-random nxombers for temporarily storing the 
verified pseudo-random numbers, the buffer means 

2 0 having an output for distributing the stored verified 

random numbers; 

first control means coupled to the buffer means, 
verification means, and the random nxmber circuit for 
activating the random number circuit and the 
25 verification means and causing the buffer means to 
deliver a set of the stored verified pseudo-random 
n\ambers on the buffer means output; 

a rules library storing indexed rules for one or 
more games; 

3 0 an interface registry for storing mapping data 

records, the mapping data records for mapping the 
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first player record to pre-selected rules in the 

iniles library; 

combinatorial algorithm storage means having a 
35 bi-directional input/ output port for storing 

combinatorial algorithms in an executable form; and 

second control means coupled to the buffer means 

output, the first player interface unit, the 

interface registry, the combinatorial algorithm 
40 storage means, and rules library, the second control 

means for processing the player record, the 

processing comprising the steps of: 

(i) accepting the first player record, 

(ii) referring to the interface registry to map 
4 5 the first player record to a selected rule in the 

rules library, 

(iii) executing the selected rule by selectively 
referring to the combinatorial algorithm storage 
means and selectively generating requests for sets of 

50 verified pseudo-random numbers from the buffer means 
output, and 

( iv ) generating an output record indicating 
results of the execution step, the output record 
directed to the first player interface unit. 

2. The apparatus of claim 1 wherein the random 
nuinber circuit comprises an ANSI X9.17 circuit. 

3. The apparatus of claim 2 wherein the random 
number circuit comprises an international data 
encryption algorithm (IDEA) encryption circuit, 

4. The apparatus of claim 2 wherein the random 
number circuit comprises a data encryption standard 
(DES) encryption circuit. 
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5. The apparatus of claim 2 wherein the random 
niomber circuit further comprises a continuously 
running clock circuit providing a clock output to the 
encryption circuit, means for providing at least one 

5 key value to the random number circuit, and means for 
providing at least one seed value to the random 
number circuit , whereby the encryption circuit 
encrypts the clock output using the at least one key 
value and the at least one seed value to provide the 
10 series of pseudo-random numbers. 

6. The apparatus of claim 1 wherein the 
verification circuit comprises means for testing 
independence of the received pseudo-random numbers. 

7. The apparatus of claim 6 wherein the means 
for testing independence uses a runs test. 

8. The apparatus of claim 1 wherein the 
verification circuit comprises means for testing 
uniformity of the received pseudo-random numbers 
using a Kolmogrorov-Smimov test. 

9. The apparatus of claim 1 wherein the 
verification circuit comprises means for testing 
uniformity of the received pseudo-random numbers 
using a Chi-square test. 

10. The apparatus of claim 1 wherein the 
verification circuit comprises means for testing 
xoniformity of the received psudo-random ninobers in 
more than one dimension using a series test. 
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11, The apparatus of claim 1 further comprising 
means coupled to the second control means for 
accepting the series of unifotialy distributed pseudo- 
random numbers and generating a series of non- 
uniformly distributed psuedo-random nimbers. 

12 . The apparatus of claim 11 wherein the 
distribution of the series of non-uniformly 
distributed pseudo-random numbers is selected from 
the group consisting of: a normal distribution, an 
exponential distribution, a Poisson distribution, a 
gamma distribution, and a hypergeometric 
distribution. 

13 • A system for implementing games for a 
plurality of players, the games having a 
deterministic component, a rule based non- 
deterministic component, and a random component, the 
system comprising: 

a plurality of player interface units, each 
generating at least at least one player record of 
information indicating player-initiated events; 

a gaming engine for implementing game rules in 
response to the at least one player record of 
information and generating random numbers required by 
the game rules; 

a player network interface circuit coupled to 
communicate with each player interface unit; 

a server network interface circuit coupled to 
communicate with the gaming engine; 

a network bus coupled to the player network 
interface circuit and the server network interface 
circuit. 
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14 . The system of claim 13 , the gaming engine 
further comprising: 

means responsive to the at least one player 
record for generating requests for sets of pseudo- 
random numbers; 

a request queue storing a number of the requests 
for sets of pseudo-random numbers. 

15. The system of claim 13 further comprising 
multitasking means within the gaming engine for 
independently and simultaneously processing each of 
the player records, generating output records for 
each of the player records, and directing the output 
records to the player interface units. 

16. The apparatus of claim 13 further 
comprising: 

first encryption means coupled to the server 
network interface circuit for encrypting information 
passed from the gaming engine to the network bus; and 

second encryption means coupled to each of the 
player network interface circuits for encrypting 
information passed from the player interface xinit to 
the network bus. 

17. A uniform random number generator 
comprising: 

at least one random nximber circuit providing a 
series of pseudo-random numbers on an output; 

verification means coupled to receive the series 
of pseudo-random numbers from the random number 
circuit for verifying that the received pseudo-random 
numbers are statistically random, the verification 
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means having an output for supplying a series of 
verified pseudo-random numbers; 

control means coupled to the verification means 
and the random number circuit for activating the 
random niamber circuit and the verification means • 

18. The uniform random number generator of 
claim 17 further comprising buffer means coupled to 
the verification means for storing numbers, the 
buffer means having an input for receiving the 
verified pseudo-random numbers from the verification 
means and an output for distributing the verified 
stored pseudo-random nximbers, 

19. The uniform random number generator of 
claim 17 wherein the random number circuit comprises 
an ANSI X9-17 circuit, 

20. The uniform random nxamber generator of 
claim 17 further comprising: 

at least two random number circuits, each of the 
at least two random number circuits having 
independent seed values and key values, the at least 
two random number circuits providing at least two 
independent series of pseudo-random numbers; and 

the control means further comprises a coupling 
to each of the at least two pseudo-random nxomber 
circuits for controllably coupling one of the at 
least two series of pseudo-random numbers to the 
verification means. 

21. The unifora random nxmber generator of 
claim 18 wherein the buffer means comprises a first 
in first out register. 
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22, The uniform random nxmber generator of 
claim 18 wherein the buffer means has a storage 
capacity and output speed sufficient to provide 
bursts of the stored verified pseudo-random numbers 

5 at a rate greater than an output rate of the 
verification means. 

23. An apparatus for implementing a game having 
a deterministic component and a non-deterministic 
component, said apparatus comprising: 

at least one player interface unit, each player 
5 interface unit generating at least player record 
indicating player- initiated events; 

a random nxamber generator providing a series of 
pseudo-random nimbers; 

a rules library storing indexed rules for one or 
10 more games; 

an interface registry for storing mapping data, 
the mapping data for mapping player record to pre- 
selected rules in the rules library; 

combinatorial algorithm storage means having a 
15 bi-directional input/output port for storing 
combinatorial algorithms in an executable form; and 

control means coupled to the player interface to 
receive the output of the player interface unit, 
coupled to the interface registry, the rules library, 
20 the combinatorial algorithm storage means, and the 
random number generator, the control means for 
processing the player record and returning an output 
record to the player interface unit. 
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24* The apparatus of claim 23 wherein the 

random niomber generator further comprises: 

a random number circuit including an encryption 
circuits- 
verification means coupled to receive the output 
signal from the random nxjmber circuit for verifying 
that the received pseudo-random numbers are 
statistically random, the verification means having 
an output for supplying a series of verified pseudo- 
random numbers; 

buffer means coupled to receive the verified 
pseudo-random niombers for temporarily storing the 
verified pseudo-random numbers, the buffer means 
having an output for distributing the stored verified 
pseudo-random numbers; and 

random number generator control means coupled to 
.the buffer means, verification means, and the pseudo- 
random number circuit for activating the random 
number circuit and the verification means and causing 
the buffer means to deliver a set of the stored 
verified random numbers on the buffer means output 
continuously • 

25 The apparatus of claim 23 wherein the 
random niomber circuit includes a clock input for 
receiving an externally generated continuously 
variable signal, the apparatus further comprising: 

means for generating a first clock signal on a 
clock output; 

means generating a second clock signal from the 
time at which the player record is generated; and 

means having an output coupled to the clock 
input for receiving and combining the first and 
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second clock signals to generate the continuously 
variable signal. 

26. A method for generating random numbers 
comprising the steps of: 

providing a signal comprising a continuously 
changing deterministic output; 
5 encrypting the signal; 

grouping the encrypted signal into sets of raw 
pseudo-random numbers; and 

verifying that the raw pseudo-random numbers 
comprise independent , Tinif orm , sets of statistically 
10 pseudo-random numbers. 

27. The method of claim. 26 further 
comprising: 

temporarily storing the verified pseudo-random 
numbers in a buffer; and 
5 distributing a portion of the stored, verified 

pseudo-random numbers from the buffer in response to 
a request from a device external to the random nxamber 
generator. 

28. An method for implementing a game, the game 
having a deterministic component, a rule based non- 
deterministic component , and a random component , the 
method comprising the steps of: 

5 generating at least a first player record of 

information indicating a player- initiated event from 
a first player; 

generating a signal comprising a series of 
uniformly distributed pseudo-random numbers; 
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10 verifying that the series of uniformly 

distributed pseudo-random numbers are statistically 
random; 

temporarily storing the verified pseudo-random 
numbers ; 

15 distributing a portion of the stored verified 

random numbers in response to a request; 

providing a rules library storing indexed rules 
for one or more games; 

providing an interface registry for storing 
20 mapping data records, the mapping data records for 
mapping the first player record to pre-selected rules 
in the rules library; and 

processing the player record, the processing 
comprising the steps of: 
25 (i) referring to the interface registry to map 

the first player record to a selected rule in the 
rules library, 

(ii) executing the selected rule by selectively 
referring to the combinatorial algorithm storage 

3 0 means and selectively generating requests for sets of 
verified pseudo-random nxambers from the buffer means 
output , and 

(iii) generating an output record indicating 
results of the execution step , the output record 

35 directed to the first player interface unit. 
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ABSTRACT OF THE DISCLOSURE 

An apparatus for implementing a game having a 
deterministic component and a non-deterministic 
component wherein a player uses the game through at 
5 least one player interface unit. Each player 
interface unit generates a player record indicating 
player-initiated events. A random number generator 
provides a series of pseudo-random numbers and a 
rules library stores indexed mles for one or more 

10 games. An interface registry stores mapping records 
where the mapping records are used to associate the 
player-initiated events to pre-selected rules in the 
rules library. A control means is coupled to the 
player interface to receive the output of the player 

15 interface unit, coupled to the interface registry, 
the rules library, and the random number generator. 
The control means processes the player record and 
returns an output record to the player interface unit 
where the output record is determined by executing 

20 the game's rules with reference to the pseudo-random 
numbers and predefined combinatorial algorithms for 
selecting sets of the pseudo-random numbers. 
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